import { getHeroListAPI } from "../../api/index"
import Variable from "../../constants/index"
import { Hero } from "../../types/hero"

// pages/search/search.ts
Page({

  /**
   * 页面的初始数据
   */
  data: {
    word: "", // 定义搜索字段
    searchWordsList: [] as string[], // 搜索历史记录
    heroList: [] as Hero[]
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad() {

  },

  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady() {

  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow() {
    // 获取缓存中的历史记录
    this.getHistoryList()
  },
  async searchList() {
    // 搜索列表
    if (this.data.word) {
      // 同步到data中，写入本地缓存就可以了
      wx.showLoading({ title: '查询中' })
      // 接口调用
      this.setData({
        heroList: await getHeroListAPI({ q: this.data.word }),
        searchWordsList: [...new Set([this.data.word,...this.data.searchWordsList])]
      }, () => {
        // 此时认为更新完成 拿到最新的数据
        console.log(this.data.searchWordsList)
        wx.setStorageSync(Variable.SEARCH_WORD_KEY, JSON.stringify(this.data.searchWordsList))
        wx.hideLoading()
      })
    }else {
      this.setData({
        heroList: []
      })
    }
  },
  // 点击搜索的方法
  toSearch(event: WechatMiniprogram.TouchEvent) {
    this.setData({
      word: event.mark?.word
    },() => {
       this.searchList() // 搜索结果
    })
  },
  // 删除关键字方法
  delWord(event: WechatMiniprogram.TouchEvent) {
    this.setData({
      searchWordsList: this.data.searchWordsList.filter(item => item !== event.mark?.word)
    }, () => {
      wx.setStorageSync(Variable.SEARCH_WORD_KEY, JSON.stringify(this.data.searchWordsList))
    })
  },
  delAll() {
    this.setData({
      searchWordsList: []
    }, () => {
       wx.removeStorageSync(Variable.SEARCH_WORD_KEY)
    })
  },
  toDetail(event:  WechatMiniprogram.TouchEvent) {
    wx.navigateTo({
      url: `/pages/hero_detail/hero_detail?heroId=${event.mark?.heroId}`
    })
  },
  getHistoryList() {
    this.setData({
      searchWordsList: JSON.parse(wx.getStorageSync(Variable.SEARCH_WORD_KEY) || "[]") as string[]
    })

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide() {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload() {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh() {

  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom() {

  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage() {

  }
})